Postgre SQL

推荐列表 站点导航

当前位置:首页 > 数据库 > Postgre SQL >

PostgreSQL中使用数组改进性能实例代码

来源:网络整理  作者:网友投稿  发布时间:2020-12-29 02:14
这篇文章主要给大家介绍了关于PostgreSQL中使用数组改进性能的相关资料,文中通过示例代码以及图文介绍的非常详细...

这篇文章主要给大家介绍了关于PostgreSQL中使用数组改进性能的相关资料,文中通过示例代码以及图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

前言

postgresql支持数组类型,可以是基本类型,也可以是用户自定义的类型。日常中使用数组类型的机会不多,但还是可以了解一下。不像C或JAVA高级语言的数组下标从0开始,postgresql数组下标从1开始,既可以指定长度,也可以不指定长度。且postgresql既支持一维数组,也支持多维数组,但是平时二维数组也就够用了。

本文将给大家介绍PostgreSQL通过数组改进性能的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧

PostgreSQL通过数组改进性能

创建一个用户和设备关系映射表,用户的设备ID存放在数组字段里面:

?

1

2

3

4

5

6

 

CREATE TABLE device.user_devices

(

user_id character varying(32) COLLATE pg_catalog."default" NOT NULL,

device_ids character varying[] COLLATE pg_catalog."default" NOT NULL,

CONSTRAINT user_devices_pkey PRIMARY KEY (user_id)

)

 

将数据导入表:

?

1

2

3

4

5

6

 

insert into device.user_devices

 select device_owner, array_agg(device_id)

 from device.device_info

 where device_owner is not null

 and device_owner != ''

 group by device_owner

 

比较原查询方式和新查询方式的性能:

原查询方式:

PostgreSQL中使用数组改进性能实例代码

新查询方式:

PostgreSQL中使用数组改进性能实例代码

可以发现新查询方式的性能有了巨大的提升!

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。

原文链接:https://yq.aliyun.com/articles/679693

相关热词:

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!

本文地址: https://v30.fanwenzhu.com/sql/pgsql/10518.shtml

下一篇:没有了
Copyright © www.juheyunku.com      关于 | 合作 | 声明 | 联系 | 更新 | 地图 | Tags

PostgreSQL中使用数组改进性能实例代码

2020-12-29 编辑:网友投稿

这篇文章主要给大家介绍了关于PostgreSQL中使用数组改进性能的相关资料,文中通过示例代码以及图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

前言

postgresql支持数组类型,可以是基本类型,也可以是用户自定义的类型。日常中使用数组类型的机会不多,但还是可以了解一下。不像C或JAVA高级语言的数组下标从0开始,postgresql数组下标从1开始,既可以指定长度,也可以不指定长度。且postgresql既支持一维数组,也支持多维数组,但是平时二维数组也就够用了。

本文将给大家介绍PostgreSQL通过数组改进性能的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧

PostgreSQL通过数组改进性能

创建一个用户和设备关系映射表,用户的设备ID存放在数组字段里面:

?

1

2

3

4

5

6

 

CREATE TABLE device.user_devices

(

user_id character varying(32) COLLATE pg_catalog."default" NOT NULL,

device_ids character varying[] COLLATE pg_catalog."default" NOT NULL,

CONSTRAINT user_devices_pkey PRIMARY KEY (user_id)

)

 

将数据导入表:

?

1

2

3

4

5

6

 

insert into device.user_devices

 select device_owner, array_agg(device_id)

 from device.device_info

 where device_owner is not null

 and device_owner != ''

 group by device_owner

 

比较原查询方式和新查询方式的性能:

原查询方式:

PostgreSQL中使用数组改进性能实例代码

新查询方式:

PostgreSQL中使用数组改进性能实例代码

可以发现新查询方式的性能有了巨大的提升!

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。

原文链接:https://yq.aliyun.com/articles/679693

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供学习参考!
本文地址为 https://v30.fanwenzhu.com/sql/pgsql/10518.shtml

相关文章

风云图片

推荐阅读

返回Postgre SQL频道首页